<!-- 我的巡更 -->

<template>
  <div v-if="param.tab === DICT.TAB[1][0]" :class="tabClass">
    <div v-if="MAP.inSearch" class="PatrolGaode-MyPatrol-btn" @click="fold = !fold">
      <span>{{ fold ? '展开' : '折叠' }}</span>
    </div>

    <MySearch />

    <MyTable />

    <MyModal />
  </div>
</template>

<script>
// ============================== 导入依赖 ============================== //

import CORE from '@/CORE'

// ============================== 导出组件 ============================== //

export default {
  /**
   * 名称定义 (实际使用名称)
   */
  name: 'MyPatrol',

  /**
   * 混入列表 (配置选项合并)
   */
  mixins: [CORE.mixWeb()],

  /**
   * 组件导入 (Abc.vue + Abc/index.vue)
   */
  ...CORE.components(
    require.context('../../PatrolReport', true, /vue$/),
    require.context('./', true, /vue$/),
  ),

  /**
   * 状态数据 (函数返回对象)
   */
  data() {
    return {
      fold: false, // 是否折叠
    }
  },

  /**
   * 计算属性 (慎用箭头函数)
   */
  computed: {
    /**
     * 页签样式类
     */
    tabClass() {
      const name = 'PatrolGaode-MyPatrol'
      const foldStr = this.fold ? ` ${name}-fold` : ''
      return `${name}${foldStr}`
    },
  },
}
</script>

<style lang="scss">
@import './index.scss';
</style>
